0
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心
发布
  • 发文章

  • 发资料

  • 发帖

  • 提问

  • 发视频

创作活动
W25Q32FWBYIG TR

W25Q32FWBYIG TR

  • 厂商:

    WINBOND(华邦)

  • 封装:

    12-UFBGA, WLCSP

  • 描述:

    IC FLASH 32M SPI 104MHZ 12WLCSP

  • 数据手册
  • 价格&库存
W25Q32FWBYIG TR 数据手册
W25Q32FW 1.8V 32M-BIT SERIAL FLASH MEMORY WITH DUAL/QUAD SPI & QPI Publication Release Date: July 01, 2016 - Revision H W25Q32FW Table of Contents 1. 2. 3. 4. 5. 6. GENERAL DESCRIPTIONS ............................................................................................................. 4 FEATURES ....................................................................................................................................... 4 PACKAGE TYPES AND PIN CONFIGURATIONS .......................................................................... 5 3.1 Pin Configuration SOIC / VSOP 208-mil .............................................................................. 5 3.2 Pad Configuration WSON 6x5-mm / 8x6-mm, XSON 4x4-mm ............................................ 5 3.3 Pin Description SOIC / VSOP 208-mil, WSON 6x5-mm / 8x6-mm, XSON 4x4-mm ............ 5 3.4 Pin Configuration SOIC 300-mil ........................................................................................... 6 3.5 Pin Description SOIC 300-mil ............................................................................................... 6 3.6 Ball Configuration TFBGA 8x6-mm (5x5 or 6x4 Ball Array) ................................................. 7 3.7 Ball Description TFBGA 8x6-mm ......................................................................................... 7 3.8 Ball Configuration WLCSP ................................................................................................... 8 3.9 Ball Description WLCSP12 ................................................................................................... 8 PIN DESCRIPTIONS ........................................................................................................................ 9 4.1 Chip Select (/CS) .................................................................................................................. 9 4.2 Serial Data Input, Output and IOs (DI, DO and IO0, IO1, IO2, IO3) .................................... 9 4.3 Write Protect (/WP)............................................................................................................... 9 4.4 HOLD (/HOLD) ..................................................................................................................... 9 4.5 Serial Clock (CLK) ................................................................................................................ 9 4.6 Reset (/RESET) .................................................................................................................... 9 BLOCK DIAGRAM .......................................................................................................................... 10 FUNCTIONAL DESCRIPTIONS ..................................................................................................... 11 6.1 SPI / QPI Operations .......................................................................................................... 11 6.1.1 6.1.2 6.1.3 6.1.4 6.1.5 6.1.6 7. Standard SPI Instructions ..................................................................................................... 11 Dual SPI Instructions ............................................................................................................ 11 Quad SPI Instructions ........................................................................................................... 12 QPI Instructions .................................................................................................................... 12 Hold Function........................................................................................................................ 12 Software Reset & Hardware /RESET pin .............................................................................. 13 6.2 Write Protection .................................................................................................................. 14 STATUS AND CONFIGURATION REGISTERS ............................................................................ 15 7.1 Status Registers ................................................................................................................. 15 7.1.1 Erase/Write In Progress (BUSY) – Status Only ................................................................. 15 7.1.2 Write Enable Latch (WEL) – Status Only ........................................................................... 15 7.1.3 Block Protect Bits (BP2, BP1, BP0) – Volatile/Non-Volatile Writable ................................. 15 7.1.4 Top/Bottom Block Protect (TB) – Volatile/Non-Volatile Writable ........................................ 16 7.1.5 Sector/Block Protect Bit (SEC) – Volatile/Non-Volatile Writable ........................................ 16 7.1.6 Complement Protect (CMP) – Volatile/Non-Volatile Writable ............................................ 16 7.1.7 Status Register Protect (SRP1, SRP0) – Volatile/Non-Volatile Writable............................ 16 7.1.8 Erase/Program Suspend Status (SUS) – Status Only ....................................................... 17 7.1.9 Security Register Lock Bits (LB[3:1]) – Volatile/Non-Volatile OTP Writable....................... 17 -1- W25Q32FW 8. 7.1.10 Quad Enable (QE) – Volatile/Non-Volatile Writable ......................................................... 17 7.1.11 Write Protect Selection (WPS) – Volatile/Non-Volatile Writable ...................................... 18 7.1.12 Output Driver Strength (DRV1, DRV0) – Volatile/Non-Volatile Writable .......................... 18 7.1.13 /HOLD or /RESET Pin Function (HOLD/RST) – Volatile/Non-Volatile Writable ............... 18 7.1.14 Reserved Bits – Non Functional ...................................................................................... 18 7.1.15 7.1.16 7.1.17 W25Q32FW Status Register Memory Protection (WPS = 0, CMP = 0) .............................. 19 W25Q32FW Status Register Memory Protection (WPS = 0, CMP = 1) .............................. 20 W25Q32FW Individual Block Memory Protection (WPS=1) ................................................ 21 INSTRUCTIONS ............................................................................................................................. 22 8.1 Device ID and Instruction Set Tables ................................................................................. 22 8.1.1 8.1.2 8.1.3 8.1.4 8.2 Manufacturer and Device Identification ................................................................................. 22 Instruction Set Table 1 (Standard SPI Instructions)(1) ........................................................... 23 Instruction Set Table 2 (Dual/Quad SPI Instructions)(1)......................................................... 24 Instruction Set Table 3 (QPI Instructions)(14) ......................................................................... 25 Instruction Descriptions ...................................................................................................... 27 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 8.2.7 8.2.8 8.2.9 8.2.10 8.2.11 8.2.12 8.2.13 8.2.14 8.2.15 8.2.16 8.2.17 8.2.18 8.2.19 8.2.20 8.2.21 8.2.22 8.2.23 8.2.24 8.2.25 8.2.26 8.2.27 8.2.28 Write Enable (06h) ................................................................................................................ 27 Write Enable for Volatile Status Register (50h)..................................................................... 27 Write Disable (04h) ............................................................................................................... 28 Read Status Register-1 (05h), Status Register-2 (35h) & Status Register-3 (15h) ............... 28 Write Status Register-1 (01h), Status Register-2 (31h) & Status Register-3 (11h) ............... 29 Read Data (03h) ................................................................................................................... 32 Fast Read (0Bh) ................................................................................................................... 33 Fast Read Dual Output (3Bh) ............................................................................................... 35 Fast Read Quad Output (6Bh) .............................................................................................. 36 Fast Read Dual I/O (BBh) ................................................................................................... 37 Fast Read Quad I/O (EBh).................................................................................................. 39 Set Burst with Wrap (77h) ................................................................................................... 42 Page Program (02h) ........................................................................................................... 43 Quad Input Page Program (32h)......................................................................................... 45 Sector Erase (20h) .............................................................................................................. 46 32KB Block Erase (52h)...................................................................................................... 47 64KB Block Erase (D8h) ..................................................................................................... 48 Chip Erase (C7h / 60h) ....................................................................................................... 49 Erase / Program Suspend (75h) ......................................................................................... 50 Erase / Program Resume (7Ah) .......................................................................................... 52 Power-down (B9h) .............................................................................................................. 53 Release Power-down / Device ID (ABh) ............................................................................. 54 Read Manufacturer / Device ID (90h) ................................................................................. 56 Read Manufacturer / Device ID Dual I/O (92h) ................................................................... 57 Read Manufacturer / Device ID Quad I/O (94h) .................................................................. 58 Read Unique ID Number (4Bh) ........................................................................................... 59 Read JEDEC ID (9Fh) ........................................................................................................ 60 Read SFDP Register (5Ah)................................................................................................. 61 -2- Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.29 8.2.30 8.2.31 8.2.32 8.2.33 8.2.34 8.2.35 8.2.36 8.2.37 8.2.38 8.2.39 8.2.40 8.2.41 9. 10. 11. Erase Security Registers (44h) ........................................................................................... 62 Program Security Registers (42h) ....................................................................................... 63 Read Security Registers (48h) ............................................................................................ 64 Set Read Parameters (C0h) ............................................................................................... 65 Burst Read with Wrap (0Ch) ............................................................................................... 66 Enter QPI Mode (38h) ......................................................................................................... 67 Exit QPI Mode (FFh) ........................................................................................................... 68 Individual Block/Sector Lock (36h) ...................................................................................... 69 Individual Block/Sector Unlock (39h) .................................................................................. 70 Read Block/Sector Lock (3Dh)............................................................................................ 71 Global Block/Sector Lock (7Eh) .......................................................................................... 72 Global Block/Sector Unlock (98h) ....................................................................................... 72 Enable Reset (66h) and Reset Device (99h) ...................................................................... 73 ELECTRICAL CHARACTERISTICS............................................................................................... 74 9.1 Absolute Maximum Ratings (1) .......................................................................................... 74 9.2 Operating Ranges .............................................................................................................. 74 9.3 Power-up Power-down Timing and Requirements ............................................................. 75 9.4 DC Electrical Characteristics .............................................................................................. 76 9.5 AC Measurement Conditions ............................................................................................. 77 9.6 AC Electrical Characteristics(6) ........................................................................................... 78 9.7 Serial Output Timing ........................................................................................................... 80 9.8 Serial Input Timing.............................................................................................................. 80 9.9 /HOLD Timing ..................................................................................................................... 80 9.10 /WP Timing ......................................................................................................................... 80 PACKAGE SPECIFICATIONS ....................................................................................................... 81 10.1 8-Pin SOIC 208-mil (Package Code SS) ............................................................................ 81 10.2 8-Pin VSOP 208-mil (Package Code ST)........................................................................... 82 10.3 8-Pad WSON 6x5-mm (Package Code ZP) ....................................................................... 83 10.4 8-Pad WSON 8x6-mm (Package Code ZE) ....................................................................... 84 10.5 Pad XSON 4x4x0.45-mm (Package Code XG) .................................................................. 85 10.6 16-Pin SOIC 300-mil (Package Code SF) .......................................................................... 86 10.7 24-Ball TFBGA 8x6-mm (Package Code TB, 5x5-1 ball array).......................................... 87 10.8 24-Ball TFBGA 8x6-mm (Package Code TC, 6x4 ball array)............................................. 88 10.9 12-Ball WLCSP (Package Code BYIC) .............................................................................. 89 10.10 12-Ball WLCSP (Package Code BYIG) ............................................................................ 90 10.11 Ordering Information ......................................................................................................... 91 10.12 Valid Part Numbers and Top Side Marking ...................................................................... 92 REVISION HISTORY ...................................................................................................................... 93 -3- W25Q32FW 1. GENERAL DESCRIPTIONS The W25Q32FW (32M-bit) Serial Flash memory provides a storage solution for systems with limited space, pins and power. The 25Q series offers flexibility and performance well beyond ordinary Serial Flash devices. They are ideal for code shadowing to RAM, executing code directly from Dual/Quad SPI (XIP) and storing voice, text and data. The device operates on a single 1.65V to 1.95V power supply with current consumption as low as 4mA active and 1µA for power-down. All devices are offered in space-saving packages. The W25Q32FW array is organized into 32,768 programmable pages of 256-bytes each. Up to 256 bytes can be programmed at a time. Pages can be erased in groups of 16 (4KB sector erase), groups of 128 (32KB block erase), groups of 256 (64KB block erase) or the entire chip (chip erase). The W25Q32FW has 1,024 erasable sectors and 64 erasable blocks respectively. The small 4KB sectors allow for greater flexibility in applications that require data and parameter storage. (See Figure 2.) The W25Q32FW support the standard Serial Peripheral Interface (SPI), Dual/Quad I/O SPI as well as 2clocks instruction cycle Quad Peripheral Interface (QPI): Serial Clock, Chip Select, Serial Data I/O0 (DI), I/O1 (DO), I/O2 (/WP), and I/O3 (/HOLD). SPI clock frequencies of up to 104MHz are supported allowing equivalent clock rates of 208MHz (104MHz x 2) for Dual I/O and 416MHz (104MHz x 4) for Quad I/O when using the Fast Read Dual/Quad I/O and QPI instructions. These transfer rates can outperform standard Asynchronous 8 and 16-bit Parallel Flash memories. The Continuous Read Mode allows for efficient memory access with as few as 8-clocks of instruction-overhead to read a 24-bit address, allowing true XIP (execute in place) operation. A Hold pin, Write Protect pin and programmable write protection, with top or bottom array control, provide further control flexibility. Additionally, the device supports JEDEC standard manufacturer and device ID, a 64-bit Unique Serial Number and three 256-bytes Security Registers. 2. FEATURES  New Family of SpiFlash Memories – W25Q32FW: 32M-bit / 4M-byte – Standard SPI: CLK, /CS, DI, DO, /WP, /Hold – Dual SPI: CLK, /CS, IO0, IO1, /WP, /Hold – Quad SPI: CLK, /CS, IO0, IO1, IO2, IO3 – QPI: CLK, /CS, IO0, IO1, IO2, IO3 – Software & Hardware Reset  Highest Performance Serial Flash – 104MHz Single, Dual/Quad SPI clocks – 208/416MHz equivalent Dual/Quad SPI – 50MB/S continuous data transfer rate – Min 100K Program-Erase cycles per sector – More than 20-year data retention  Efficient “Continuous Read” and QPI Mode – Continuous Read with 8/16/32/64-Byte Wrap – As few as 8 clocks to address memory – Quad Peripheral Interface (QPI) reduces instruction overhead – Allows true XIP (execute in place) operation – Outperforms X16 Parallel Flash  Flexible Architecture with 4KB sectors – Uniform Sector/Block Erase (4K/32K/64K-Byte) – Program 1 to 256 byte per programmable page – Erase/Program Suspend & Resume  Advanced Security Features – Software and Hardware Write-Protect – Power Supply Lock-Down and OTP protection – Top/Bottom, Complement array protection – Individual Block/Sector array protection – 64-Bit Unique ID for each device – Discoverable Parameters (SFDP) Register – 3X256-Bytes Security Registers with OTP locks – Volatile & Non-volatile Status Register Bits  Space Efficient Packaging – 8-pin SOIC/VSOP 208-mil, XSON 4x4-mm – 8-pad WSON 6x5-mm / 8x6-mm – 16-pin SOIC 300-mil (additional /RESET) – 24-ball TFBGA 8x6-mm(additional /RESET) – 12-ball WLCSP – Contact Winbond for KGD and other options -4- Publication Release Date: July 01, 2016 - Revision H W25Q32FW 3. PACKAGE TYPES AND PIN CONFIGURATIONS 3.1 Pin Configuration SOIC / VSOP 208-mil Top View /CS 1 8 VCC DO (IO1) 2 7 /HOLD or /RESET (IO3) /WP (IO2) 3 6 CLK GND 4 5 DI (IO0) Figure 1a. W25Q32FW Pin Assignments, 8-pin SOIC / VSOP 208-mil (Package Code SS, ST) 3.2 Pad Configuration WSON 6x5-mm / 8x6-mm, XSON 4x4-mm Top View /CS 1 8 VCC DO (IO1) 2 7 /HOLD or /RESET (IO3) /WP (IO2) 3 6 CLK GND 4 5 DI (IO0) Figure 1b. W25Q32FW Pad Assignments, 8-pad WSON 6x5-mm / 8x6-mm, XSON 4x4-mm (Package Code ZP, ZE, XG) 3.3 Pin Description SOIC / VSOP 208-mil, WSON 6x5-mm / 8x6-mm, XSON 4x4-mm PIN NO. PIN NAME I/O FUNCTION 1 /CS I 2 DO (IO1) I/O Data Output (Data Input Output 1)(1) 3 /WP (IO2) I/O Write Protect Input ( Data Input Output 2)(2) 4 GND 5 DI (IO0) I/O 6 CLK I 7 /HOLD or /RESET (IO3) I/O 8 VCC Chip Select Input Ground Data Input (Data Input Output 0)(1) Serial Clock Input Hold or Reset Input (Data Input Output 3)(2) Power Supply Notes: 1. IO0 and IO1 are used for Standard and Dual SPI instructions 2. IO0 – IO3 are used for Quad SPI instructions, /WP & /HOLD (or /RESET) functions are only available for Standard/Dual SPI. -5- W25Q32FW 3.4 Pin Configuration SOIC 300-mil Top View /HOLD (IO3) 1 16 CLK VCC 2 15 DI (IO0) /RESET 3 14 NC NC 4 13 NC NC 5 12 NC NC 6 11 NC /CS 7 10 GND DO (IO1) 8 9 /WP (IO2) Figure 1c. W25Q32FW Pin Assignments, 16-pin SOIC 300-mil (Package Code SF) 3.5 Pin Description SOIC 300-mil PIN NO. PIN NAME I/O FUNCTION 1 /HOLD (IO3) I/O 2 VCC 3 /RESET 4 N/C No Connect 5 N/C No Connect 6 N/C No Connect 7 /CS I 8 DO (IO1) I/O Data Output (Data Input Output 1)(1) 9 /WP (IO2) I/O Write Protect Input (Data Input Output 2)(2) 10 GND Ground 11 N/C No Connect 12 N/C No Connect 13 N/C No Connect 14 N/C No Connect 15 DI (IO0) I/O 16 CLK I Hold Input (Data Input Output 3)(2) Power Supply I Reset Input(3) Chip Select Input Data Input (Data Input Output 0)(1) Serial Clock Input Notes: 1. IO0 and IO1 are used for Standard and Dual SPI instructions 2. IO0 – IO3 are used for Quad SPI instructions, /WP & /HOLD (or /RESET) functions are only available for Standard/Dual SPI. 3. The /RESET pin on SOIC-16 package is independent of the HOLD/RST bit and QE bit settings in the Status Register. This pin can be left floating in the system if RESET function is not needed. -6- Publication Release Date: July 01, 2016 - Revision H W25Q32FW 3.6 Ball Configuration TFBGA 8x6-mm (5x5 or 6x4 Ball Array) Top View Top View A1 A2 A3 A4 A2 A3 A4 A5 NC NC NC /RESET NC NC /RESET NC B1 B2 B3 B4 B1 B2 B3 B4 B5 NC CLK GND VCC NC CLK GND VCC NC C1 C2 C3 C4 C1 C2 C3 C4 C5 NC /CS NC /WP (IO2) NC /CS NC /WP (IO2) NC D1 D2 D3 D4 D3 D4 D1 D2 NC DO(IO1) DI(IO0) /HOLD(IO3) D5 NC DO(IO1) NC E1 E2 E3 E4 DI(IO0) /HOLD(IO3) E1 E2 E3 E4 E5 NC NC NC NC NC NC NC NC NC F1 F2 F3 F4 NC NC NC NC Package Code TB Package Code TC Figure 1d. W25Q32FW Ball Assignments, 24-ball TFBGA 8x6-mm (Package Code TB, TC) 3.7 Ball Description TFBGA 8x6-mm BALL NO. PIN NAME I/O FUNCTION A4 /RESET I Reset Input B2 CLK I Serial Clock Input B3 GND Ground B4 VCC Power Supply C2 /CS I C4 /WP (IO2) I/O Write Protect Input (Data Input Output 2)(2) D2 DO (IO1) I/O Data Output (Data Input Output 1)(1) D3 DI (IO0) I/O Data Input (Data Input Output 0)(1) D4 /HOLD (IO3) I/O Hold Input (Data Input Output 3)(2) Multiple NC Chip Select Input No Connect Notes: 1. IO0 and IO1 are used for Standard and Dual SPI instructions 2. IO0 – IO3 are used for Quad SPI instructions, /WP & /HOLD (or /RESET) functions are only available for Standard/Dual SPI. -7- W25Q32FW 3.8 Ball Configuration WLCSP Top View Bottom View A1 A2 A3 A3 A2 A1 NC Vcc /CS /CS Vcc NC B1 B2 B3 B3 B2 B1 NC /HOLD(IO3) DO(IO1) DO(IO1) /HOLD(IO3) NC C1 C2 C3 NC CLK /WP(IO2) C3 D1 D2 D3 D3 NC DI(IO0) Vss Vss /WP(IO2) C2 C1 CLK NC D2 D1 DI(IO0) NC Figure 1e. W25Q32FW Ball Assignments for the WLCSP12 (Package Code BY) 3.9 Ball Description WLCSP12 BALL NO. PIN NAME I/O FUNCTION A2 VCC B2 /HOLD or /RESET (IO3) I/O C2 CLK I D2 DI (IO0) I/O A3 /CS I B3 DO (IO1) I/O Data Output (Data Input Output 1)(1) C3 /WP (IO2) I/O Write Protect Input (Data Input Output 2)(2) D3 GND Multiple NC Power Supply Hold Input or /RESET (Data Input Output 3)(2) Serial Clock Input Data Input (Data Input Output 0)(1) Chip Select Input Ground No Connect Notes: 1. IO0 and IO1 are used for Standard and Dual SPI instructions 2. IO0 – IO3 are used for Quad SPI instructions, /WP & /HOLD (or /RESET) functions are only available for Standard/Dual SPI. -8- Publication Release Date: July 01, 2016 - Revision H W25Q32FW 4. PIN DESCRIPTIONS 4.1 Chip Select (/CS) The SPI Chip Select (/CS) pin enables and disables device operation. When /CS is high the device is deselected and the Serial Data Output (DO, or IO0, IO1, IO2, IO3) pins are at high impedance. When deselected, the devices power consumption will be at standby levels unless an internal erase, program or write status register cycle is in progress. When /CS is brought low the device will be selected, power consumption will increase to active levels and instructions can be written to and data read from the device. After power-up, /CS must transition from high to low before a new instruction will be accepted. The /CS input must track the VCC supply level at power-up and power-down (see “Write Protection” and Figure 57). If needed a pull-up resistor on the /CS pin can be used to accomplish this. 4.2 Serial Data Input, Output and IOs (DI, DO and IO0, IO1, IO2, IO3) The W25Q32FW supports standard SPI, Dual SPI and Quad SPI operation. Standard SPI instructions use the unidirectional DI (input) pin to serially write instructions, addresses or data to the device on the rising edge of the Serial Clock (CLK) input pin. Standard SPI also uses the unidirectional DO (output) to read data or status from the device on the falling edge of CLK. Dual and Quad SPI instructions use the bidirectional IO pins to serially write instructions, addresses or data to the device on the rising edge of CLK and read data or status from the device on the falling edge of CLK. Quad SPI instructions require the non-volatile Quad Enable bit (QE) in Status Register-2 to be set. When QE=1, the /WP pin becomes IO2 and /HOLD pin becomes IO3. 4.3 Write Protect (/WP) The Write Protect (/WP) pin can be used to prevent the Status Register from being written. Used in conjunction with the Status Register’s Block Protect (CMP, SEC, TB, BP2, BP1 and BP0) bits and Status Register Protect (SRP) bits, a portion as small as a 4KB sector or the entire memory array can be hardware protected. The /WP pin is active low. When the QE bit of Status Register-2 is set for Quad I/O, the /WP pin function is not available since this pin is used for IO2. See Figure 1a-d for the pin configuration of Quad I/O operation. 4.4 HOLD (/HOLD) The /HOLD pin allows the device to be paused while it is actively selected. When /HOLD is brought low, while /CS is low, the DO pin will be at high impedance and signals on the DI and CLK pins will be ignored (don’t care). When /HOLD is brought high, device operation can resume. The /HOLD function can be useful when multiple devices are sharing the same SPI signals. The /HOLD pin is active low. When the QE bit of Status Register-2 is set for Quad I/O, the /HOLD pin function is not available since this pin is used for IO3. See Figure 1a-d for the pin configuration of Quad I/O operation. 4.5 Serial Clock (CLK) The SPI Serial Clock Input (CLK) pin provides the timing for serial input and output operations. ("See SPI Operations") 4.6 Reset (/RESET) The /RESET pin allows the device to be reset by the controller. For 8-pin packages, when QE=0, the IO3 pin can be configured either as a /HOLD pin or as a /RESET pin depending on Status Register setting. When QE=1, the /HOLD or /RESET function is not available for 8-pin configuration. On the 16-pin SOIC and TFBGA package, a dedicated /RESET pin is provided and it is independent of QE bit setting. -9- W25Q32FW 5. BLOCK DIAGRAM SFDP Register 000000h Security Register 1 - 3 0000FFh 003000h 002000h 001000h 0030FFh 0020FFh 0010FFh Block Segmentation xxFF00h • xxF000h Sector 15 (4KB) xxFFFFh • xxF0FFh xxEF00h • xxE000h Sector 14 (4KB) xxEFFFh • xxE0FFh xxDF00h • xxD000h Sector 13 (4KB) xxDFFFh • xxD0FFh 3FFF00h • 3F0000h xx2FFFh • xx20FFh xx1F00h • xx1000h Sector 1 (4KB) xx1FFFh • xx10FFh xx0F00h • xx0000h Sector 0 (4KB) xx0FFFh • xx00FFh 20FF00h • 200000h Block 32 (64KB) 20FFFFh • 2000FFh 1FFF00h • 1F0000h Block 31 (64KB) 1FFFFFh • 1F00FFh • • • Write Control Logic Status Register 10FF00h • 100000h Block 16 (64KB) 10FFFFh • 1000FFh 0FFF00h • 0F0000h Block 15 (64KB) 0FFFFFh • 0F00FFh • • • High Voltage Generators 00FF00h • 000000h /HOLD (IO3) or /RESET (IO3) /CS SPI Command & Control Logic W25Q32FV Sector 2 (4KB) Write Protect Logic and Row Decode xx2F00h • xx2000h CLK 3FFFFFh • 3F00FFh • • • • • • /WP (IO2) Block 63 (64KB) Page Address Latch / Counter Block 0 (64KB) Beginning Page Address 00FFFFh • 0000FFh Ending Page Address Column Decode And 256-Byte Page Buffer Data DI (IO0) DO (IO1) Byte Address Latch / Counter Figure 2. W25Q32FW Serial Flash Memory Block Diagram - 10 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 6. FUNCTIONAL DESCRIPTIONS 6.1 SPI / QPI Operations Power Up Device Initialization & Status Register Refresh (Non-Volatile Cells) Hardware Reset Standard SPI Dual SPI Quad SPI Enable QPI (38h) Hardware Reset SPI Reset (66h + 99h) Disable QPI (FFh) QPI QPI Reset (66h + 99h) Figure 3. W25Q32FW Serial Flash Memory Operation Diagram 6.1.1 Standard SPI Instructions The W25Q32FW is accessed through an SPI compatible bus consisting of four signals: Serial Clock (CLK), Chip Select (/CS), Serial Data Input (DI) and Serial Data Output (DO). Standard SPI instructions use the DI input pin to serially write instructions, addresses or data to the device on the rising edge of CLK. The DO output pin is used to read data or status from the device on the falling edge of CLK. SPI bus operation Mode 0 (0,0) and 3 (1,1) are supported. The primary difference between Mode 0 and Mode 3 concerns the normal state of the CLK signal when the SPI bus master is in standby and data is not being transferred to the Serial Flash. For Mode 0, the CLK signal is normally low on the falling and rising edges of /CS. For Mode 3, the CLK signal is normally high on the falling and rising edges of /CS. 6.1.2 Dual SPI Instructions The W25Q32FW supports Dual SPI operation when using instructions such as “Fast Read Dual Output (3Bh)” and “Fast Read Dual I/O (BBh)”. These instructions allow data to be transferred to or from the device at two to three times the rate of ordinary Serial Flash devices. The Dual SPI Read instructions are ideal for quickly downloading code to RAM upon power-up (code-shadowing) or for executing non-speed-critical code directly from the SPI bus (XIP). When using Dual SPI instructions, the DI and DO pins become bidirectional I/O pins: IO0 and IO1. - 11 - W25Q32FW 6.1.3 Quad SPI Instructions The W25Q32FW supports Quad SPI operation when using instructions such as “Fast Read Quad Output (6Bh)”, and “Fast Read Quad I/O (EBh). These instructions allow data to be transferred to or from the device four to six times the rate of ordinary Serial Flash. The Quad Read instructions offer a significant improvement in continuous and random access transfer rates allowing fast code-shadowing to RAM or execution directly from the SPI bus (XIP). When using Quad SPI instructions the DI and DO pins become bidirectional IO0 and IO1, and the /WP and /HOLD pins become IO2 and IO3 respectively. Quad SPI instructions require the non-volatile Quad Enable bit (QE) in Status Register-2 to be set. 6.1.4 QPI Instructions The W25Q32FW supports Quad Peripheral Interface (QPI) operations only when the device is switched from Standard/Dual/Quad SPI mode to QPI mode using the “Enter QPI (38h)” instruction. The typical SPI protocol requires that the byte-long instruction code being shifted into the device only via DI pin in eight serial clocks. The QPI mode utilizes all four IO pins to input the instruction code, thus only two serial clocks are required. This can significantly reduce the SPI instruction overhead and improve system performance in an XIP environment. Standard/Dual/Quad SPI mode and QPI mode are exclusive. Only one mode can be active at any given time. “Enter QPI (38h)” and “Exit QPI (FFh)” instructions are used to switch between these two modes. Upon power-up or after a software reset using “Reset (99h)” instruction, the default state of the device is Standard/Dual/Quad SPI mode. To enable QPI mode, the non-volatile Quad Enable bit (QE) in Status Register-2 is required to be set. When using QPI instructions, the DI and DO pins become bidirectional IO0 and IO1, and the /WP and /HOLD pins become IO2 and IO3 respectively. See Figure 3 for the device operation modes. 6.1.5 Hold Function For Standard SPI and Dual SPI operations, the /HOLD signal allows the W25Q32FW operation to be paused while it is actively selected (when /CS is low). The /HOLD function may be useful in cases where the SPI data and clock signals are shared with other devices. For example, consider if the page buffer was only partially written when a priority interrupt requires use of the SPI bus. In this case the /HOLD function can save the state of the instruction and the data in the buffer so programming can resume where it left off once the bus is available again. The /HOLD function is only available for standard SPI and Dual SPI operation, not during Quad SPI or QPI. The Quad Enable Bit QE in Status Register-2 is used to determine if the pin is used as /HOLD pin or data I/O pin. When QE=0 (factory default), the pin is /HOLD, when QE=1, the pin will become an I/O pin, /HOLD function is no longer available. To initiate a /HOLD condition, the device must be selected with /CS low. A /HOLD condition will activate on the falling edge of the /HOLD signal if the CLK signal is already low. If the CLK is not already low the /HOLD condition will activate after the next falling edge of CLK. The /HOLD condition will terminate on the rising edge of the /HOLD signal if the CLK signal is already low. If the CLK is not already low the /HOLD condition will terminate after the next falling edge of CLK. During a /HOLD condition, the Serial Data Output (DO) is high impedance, and Serial Data Input (DI) and Serial Clock (CLK) are ignored. The Chip Select (/CS) signal should be kept active (low) for the full duration of the /HOLD operation to avoid resetting the internal logic state of the device. - 12 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 6.1.6 Software Reset & Hardware /RESET pin The W25Q32FW can be reset to the initial power-on state by a software Reset sequence, either in SPI mode or QPI mode. This sequence must include two consecutive commands: Enable Reset (66h) & Reset (99h). If the command sequence is successfully accepted, the device will take approximately 30uS (tRST) to reset. No command will be accepted during the reset period. For the 8-pin and TFBGA package types, W25Q32FW can also be configured to utilize a hardware /RESET pin. The HOLD/RST bit in the Status Register-3 is the configuration bit for /HOLD pin function or RESET pin function. When HOLD/RST=0 (factory default), the pin acts as a /HOLD pin as described above; when HOLD/RST=1, the pin acts as a /RESET pin. Drive the /RESET pin low for a minimum period of ~1us (tRESET*) will reset the device to its initial power-on state. Any on-going Program/Erase operation will be interrupted and data corruption may happen. While /RESET is low, the device will not accept any command input. If QE bit is set to 1 on the 8-pin packages, the /HOLD or /RESET function will be disabled, the pin will become one of the four data I/O pins. For the SOIC-16 package, W25Q32FW provides a dedicated /RESET pin in addition to the /HOLD (IO 3) pin as illustrated in Figure 1b. Drive the /RESET pin low for a minimum period of ~1us (tRESET*) will reset the device to its initial power-on state. The HOLD/RST bit or QE bit in the Status Register will not affect the function of this dedicated /RESET pin. There is an internal pull-up resistor for the dedicated /RESET pin on the SOIC-16 package. If the reset function is not needed, this pin can be left floating in the system. Hardware /RESET pin has the highest priority among all the input signals. Drive /RESET low for a minimum period of ~1us (tRESET*) will interrupt any on-going external/internal operations, regardless the status of other SPI signals (/CS, CLK, IOs, /WP and/or /HOLD). Note: While a faster /RESET pulse (as short as a few hundred nanoseconds) will often reset the device, a 1us minimum is recommended to ensure reliable operation. - 13 - W25Q32FW 6.2 Write Protection Applications that use non-volatile memory must take into consideration the possibility of noise and other adverse system conditions that may compromise data integrity. To address this concern, the W25Q32FW provides several means to protect the data from inadvertent writes.         Device resets when VCC is below threshold Time delay write disable after Power-up Write enable/disable instructions and automatic write disable after erase or program Software and Hardware (/WP pin) write protection using Status Registers Additional Individual Block/Sector Locks for array protection Write Protection using Power-down instruction Lock Down write protection for Status Register until the next power-up One Time Program (OTP) write protection for array and Security Registers using Status Register* * Note: This feature is available upon special order. Please contact Winbond for details. Upon power-up or at power-down, the W25Q32FW will maintain a reset condition while VCC is below the threshold value of VWI, (See Power-up Timing and Voltage Levels and Figure 57). While reset, all operations are disabled and no instructions are recognized. During power-up and after the VCC voltage exceeds VWI, all program and erase related instructions are further disabled for a time delay of t PUW. This includes the Write Enable, Page Program, Sector Erase, Block Erase, Chip Erase and the Write Status Register instructions. Note that the chip select pin (/CS) must track the VCC supply level at power-up until the VCC-min level and tVSL time delay is reached, and it must also track the VCC supply level at powerdown to prevent adverse command sequence. If needed a pull-up resistor on /CS can be used to accomplish this. After power-up the device is automatically placed in a write-disabled state with the Status Register Write Enable Latch (WEL) set to a 0. A Write Enable instruction must be issued before a Page Program, Sector Erase, Block Erase, Chip Erase or Write Status Register instruction will be accepted. After completing a program, erase or write instruction the Write Enable Latch (WEL) is automatically cleared to a write-disabled state of 0. Software controlled write protection is facilitated using the Write Status Register instruction and setting the Status Register Protect (SRP0, SRP1) and Block Protect (CMP, SEC, TB, BP[2:0]) bits. These settings allow a portion or the entire memory array to be configured as read only. Used in conjunction with the Write Protect (/WP) pin, changes to the Status Register can be enabled or disabled under hardware control. See Status Register section for further information. Additionally, the Power-down instruction offers an extra level of write protection as all instructions are ignored except for the Release Power-down instruction. The W25Q32FW also provides another Write Protect method using the Individual Block Locks. Each 64KB block (except the top and bottom blocks, total of 62 blocks) and each 4KB sector within the top/bottom blocks (total of 32 sectors) are equipped with an Individual Block Lock bit. When the lock bit is 0, the corresponding sector or block can be erased or programmed; when the lock bit is set to 1, Erase or Program commands issued to the corresponding sector or block will be ignored. When the device is powered on, all Individual Block Lock bits will be 1, so the entire memory array is protected from Erase/Program. An “Individual Block Unlock (39h)” instruction must be issued to unlock any specific sector or block. The WPS bit in Status Register-3 is used to decide which Write Protect scheme should be used. When WPS=0 (factory default), the device will only utilize CMP, SEC, TB, BP[2:0] bits to protect specific areas of the array; when WPS=1, the device will utilize the Individual Block Locks for write protection. - 14 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 7. STATUS AND CONFIGURATION REGISTERS Three Status and Configuration Registers are provided for W25Q32FW. The Read Status Register-1/2/3 instructions can be used to provide status on the availability of the flash memory array, whether the device is write enabled or disabled, the state of write protection, Quad SPI setting, Security Register lock status, Erase/Program Suspend status, output driver strength, and power-up. The Write Status Register instruction can be used to configure the device write protection features, Quad SPI setting, Security Register OTP locks, Hold/Reset functions, and output driver strength. Write access to the Status Register is controlled by the state of the non-volatile Status Register Protect bits (SRP0, SRP1), the Write Enable instruction, and during Standard/Dual SPI operations, the /WP pin. 7.1 Status Registers S7 S6 S5 S4 S3 S2 S1 S0 SRP0 SEC TB BP2 BP1 BP0 WEL BUSY Status Register Protect 0 (Volatile/Non-Volatile Writable) Sector Protect Bit (Volatile/Non-Volatile Writable) Top/Bottom Protect Bit (Volatile/Non-Volatile Writable) Block Protect Bits (Volatile/Non-Volatile Writable) Write Enable Latch (Status-Only) Erase/Write In Progress (Status-Only) Figure 4a. Status Register-1 7.1.1 Erase/Write In Progress (BUSY) – Status Only BUSY is a read only bit in the status register (S0) that is set to a 1 state when the device is executing a Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register or Erase/Program Security Register instruction. During this time the device will ignore further instructions except for the Read Status Register and Erase/Program Suspend instruction (see tW , tPP, tSE, tBE, and tCE in AC Characteristics). When the program, erase or write status/security register instruction has completed, the BUSY bit will be cleared to a 0 state indicating the device is ready for further instructions. 7.1.2 Write Enable Latch (WEL) – Status Only Write Enable Latch (WEL) is a read only bit in the status register (S1) that is set to 1 after executing a Write Enable Instruction. The WEL status bit is cleared to 0 when the device is write disabled. A write disable state occurs upon power-up or after any of the following instructions: Write Disable, Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register, Erase Security Register and Program Security Register. 7.1.3 Block Protect Bits (BP2, BP1, BP0) – Volatile/Non-Volatile Writable The Block Protect Bits (BP2, BP1, BP0) are non-volatile read/write bits in the status register (S4, S3, and S2) that provide Write Protection control and status. Block Protect bits can be set using the Write Status Register Instruction (see tW in AC characteristics). All, none or a portion of the memory array can be protected from Program and Erase instructions (see Status Register Memory Protection table). The factory default setting for the Block Protection Bits is 0, none of the array protected. - 15 - W25Q32FW 7.1.4 Top/Bottom Block Protect (TB) – Volatile/Non-Volatile Writable The non-volatile Top/Bottom bit (TB) controls if the Block Protect Bits (BP2, BP1, BP0) protect from the Top (TB=0) or the Bottom (TB=1) of the array as shown in the Status Register Memory Protection table. The factory default setting is TB=0. The TB bit can be set with the Write Status Register Instruction depending on the state of the SRP0, SRP1 and WEL bits. 7.1.5 Sector/Block Protect Bit (SEC) – Volatile/Non-Volatile Writable The non-volatile Sector/Block Protect bit (SEC) controls if the Block Protect Bits (BP2, BP1, BP0) protect either 4KB Sectors (SEC=1) or 64KB Blocks (SEC=0) in the Top (TB=0) or the Bottom (TB=1) of the array as shown in the Status Register Memory Protection table. The default setting is SEC=0. 7.1.6 Complement Protect (CMP) – Volatile/Non-Volatile Writable The Complement Protect bit (CMP) is a non-volatile read/write bit in the status register (S14). It is used in conjunction with SEC, TB, BP2, BP1 and BP0 bits to provide more flexibility for the array protection. Once CMP is set to 1, previous array protection set by SEC, TB, BP2, BP1 and BP0 will be reversed. For instance, when CMP=0, a top 64KB block can be protected while the rest of the array is not; when CMP=1, the top 64KB block will become unprotected while the rest of the array become read-only. Please refer to the Status Register Memory Protection table for details. The default setting is CMP=0. 7.1.7 Status Register Protect (SRP1, SRP0) – Volatile/Non-Volatile Writable The Status Register Protect bits (SRP1 and SRP0) are non-volatile read/write bits in the status register (S8 and S7). The SRP bits control the method of write protection: software protection, hardware protection, power supply lock-down or one time programmable (OTP) protection. SRP1 SRP0 /WP Status Register Description 0 0 X Software Protection /WP pin has no control. The Status register can be written to after a Write Enable instruction, WEL=1. [Factory Default] 0 1 0 Hardware Protected When /WP pin is low the Status Register locked and cannot be written to. 0 1 1 Hardware Unprotected 1 0 X Power Supply Lock-Down 1 1 X One Time Program(2) When /WP pin is high the Status register is unlocked and can be written to after a Write Enable instruction, WEL=1. Status Register is protected and cannot be written to again until the next power-down, power-up cycle.(1) Status Register is permanently protected and cannot be written to. Notes: 1. When SRP1, SRP0 = (1, 0), a power-down, power-up cycle will change SRP1, SRP0 to (0, 0) state. 2. This feature is available upon special order. Please contact Winbond for details. - 16 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW S15 S14 S13 S12 S11 S10 S9 S8 SUS CMP LB3 LB2 LB1 (R) QE SRP1 SUSPEND STATUS COMPLEMENT PROTECT (non-volatile) SECURITY REGISTER LOCK BITS (non-volatile OTP) RESERVED QUAD ENABLE (non-volatile) STATUS REGISTER PROTECT 1 (non-volatile) Figure 4b. Status Register-2 7.1.8 Erase/Program Suspend Status (SUS) – Status Only The Suspend Status bit is a read only bit in the status register (S15) that is set to 1 after executing a Erase/Program Suspend (75h) instruction. The SUS status bit is cleared to 0 by Erase/Program Resume (7Ah) instruction as well as a power-down, power-up cycle. 7.1.9 Security Register Lock Bits (LB[3:1]) – Volatile/Non-Volatile OTP Writable The Security Register Lock Bits (LB3, LB2, LB1) are non-volatile One Time Program (OTP) bits in Status Register (S13, S12, S11) that provide the write protect control and status to the Security Registers. The default state of LB3-1 is 0, Security Registers are unlocked. LB3-1 can be set to 1 individually using the Write Status Register instruction. LB3-1 are One Time Programmable (OTP), once it’s set to 1, the corresponding 256-Byte Security Register will become read-only permanently. 7.1.10 Quad Enable (QE) – Volatile/Non-Volatile Writable The Quad Enable (QE) bit is a non-volatile read/write bit in the status register (S9) that allows Quad SPI and QPI operation. When the QE bit is set to a 0 state ((factory default for part numbers with ordering options “IG” and “IF”), the /WP pin and /HOLD are enabled. When the QE bit is set to a 1(factory default for Quad Enabled part numbers with ordering option “IQ”), the Quad IO2 and IO3 pins are enabled, and /WP and /HOLD functions are disabled. QE bit is required to be set to a 1 before issuing an “Enter QPI (38h)” to switch the device from Standard/Dual/Quad SPI to QPI, otherwise the command will be ignored. When the device is in QPI mode, QE bit will remain to be 1. A “Write Status Register” command in QPI mode cannot change QE bit from a “1” to a “0”. WARNING: If the /WP or /HOLD pins are tied directly to the power supply or ground during standard SPI or Dual SPI operation, the QE bit should never be set to a 1. - 17 - W25Q32FW S23 S22 S21 HOLD DRV1 DRV0 /RST S20 S19 S18 S17 S16 (R) (R) WPS (R) (R) /HOLD or /RESET Function (Volatile/Non-Volatile Writable) Output Driver Strength (Volatile/Non-Volatile Writable) Reserved Write Protect Selection (Volatile/Non-Volatile Writable) Reserved Figure 4c. Status Register-3 7.1.11 Write Protect Selection (WPS) – Volatile/Non-Volatile Writable The WPS bit is used to select which Write Protect scheme should be used. When WPS=0, the device will use the combination of CMP, SEC, TB, BP[2:0] bits to protect a specific area of the memory array. When WPS=1, the device will utilize the Individual Block Locks to protect any individual sector or blocks. The default value for all Individual Block Lock bits is 1 upon device power on or after reset. 7.1.12 Output Driver Strength (DRV1, DRV0) – Volatile/Non-Volatile Writable The DRV1 & DRV0 bits are used to determine the output driver strength for the Read operations. DRV1, DRV0 Driver Strength 0, 0 100% 0, 1 75% 1, 0 50% 1, 1 25% (default) 7.1.13 /HOLD or /RESET Pin Function (HOLD/RST) – Volatile/Non-Volatile Writable The HOLD/RST bit is used to determine whether /HOLD or /RESET function should be implemented on the hardware pin for 8-pin packages. When HOLD/RST=0 (factory default), the pin acts as /HOLD; when HOLD/RST=1, the pin acts as /RESET. However, /HOLD or /RESET functions are only available when QE=0. If QE is set to 1, the /HOLD and /RESET functions are disabled, the pin acts as a dedicated data I/O pin. 7.1.14 Reserved Bits – Non Functional There are a few reserved Status Register bits that may be read out as a “0” or “1”. It is recommended to ignore the values of those bits. During a “Write Status Register” instruction, the Reserved Bits can be written as “0”, but there will not be any effects. - 18 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 7.1.15 W25Q32FW Status Register Memory Protection (WPS = 0, CMP = 0) STATUS REGISTER(1) W25Q32FW (32M-BIT) MEMORY PROTECTION(3) SEC TB BP2 BP1 BP0 PROTECTED BLOCK(S) PROTECTED ADDRESSES PROTECTED DENSITY PROTECTED PORTION(2) X X 0 0 0 NONE NONE NONE NONE 0 0 0 0 1 63 3F0000h – 3FFFFFh 64KB Upper 1/64 0 0 0 1 0 62 and 63 3E0000h – 3FFFFFh 128KB Upper 1/32 0 0 0 1 1 60 thru 63 3C0000h – 3FFFFFh 256KB Upper 1/16 0 0 1 0 0 56 thru 63 380000h – 3FFFFFh 512KB Upper 1/8 0 0 1 0 1 48 thru 63 300000h – 3FFFFFh 1MB Upper 1/4 0 0 1 1 0 32 thru 63 200000h – 3FFFFFh 2MB Upper 1/2 0 1 0 0 1 0 000000h – 00FFFFh 64KB Lower 1/64 0 1 0 1 0 0 and 1 000000h – 01FFFFh 128KB Lower 1/32 0 1 0 1 1 0 thru 3 000000h – 03FFFFh 256KB Lower 1/16 0 1 1 0 0 0 thru 7 000000h – 07FFFFh 512KB Lower 1/8 0 1 1 0 1 0 thru 15 000000h – 0FFFFFh 1MB Lower 1/4 0 1 1 1 0 0 thru 31 000000h – 1FFFFFh 2MB Lower 1/2 X X 1 1 1 0 thru 63 000000h – 3FFFFFh 4MB ALL 1 0 0 0 1 63 3FF000h – 3FFFFFh 4KB U - 1/1024 1 0 0 1 0 63 3FE000h – 3FFFFFh 8KB U - 1/512 1 0 0 1 1 63 3FC000h – 3FFFFFh 16KB U - 1/256 1 0 1 0 X 63 3F8000h – 3FFFFFh 32KB U - 1/128 1 1 0 0 1 0 000000h – 000FFFh 4KB L - 1/1024 1 1 0 1 0 0 000000h – 001FFFh 8KB L - 1/512 1 1 0 1 1 0 000000h – 003FFFh 16KB L - 1/256 1 1 1 0 X 0 000000h – 007FFFh 32KB L - 1/128 Notes: 1. X = don’t care 2. L = Lower; U = Upper 3. If any Erase or Program command specifies a memory region that contains protected data portion, this command will be ignored. - 19 - W25Q32FW 7.1.16 W25Q32FW Status Register Memory Protection (WPS = 0, CMP = 1) STATUS REGISTER(1) W25Q32FW (32M-BIT) MEMORY PROTECTION(3) SEC TB BP2 BP1 BP0 PROTECTED BLOCK(S) PROTECTED ADDRESSES PROTECTED DENSITY PROTECTED PORTION(2) X X 0 0 0 0 thru 63 000000h – 3FFFFFh 4MB ALL 0 0 0 0 1 0 thru 62 000000h – 3EFFFFh 4,032KB Lower 63/64 0 0 0 1 0 0 and 61 000000h – 3DFFFFh 3,968KB Lower 31/32 0 0 0 1 1 0 thru 59 000000h – 3BFFFFh 3,840KB Lower 15/16 0 0 1 0 0 0 thru 55 000000h – 37FFFFh 3,584KB Lower 7/8 0 0 1 0 1 0 thru 47 000000h – 2FFFFFh 3MB Lower 3/4 0 0 1 1 0 0 thru 31 000000h – 1FFFFFh 2MB Lower 1/2 0 1 0 0 1 1 thru 63 010000h – 3FFFFFh 4,032KB Upper 63/64 0 1 0 1 0 2 and 63 020000h – 3FFFFFh 3,968KB Upper 31/32 0 1 0 1 1 4 thru 63 040000h – 3FFFFFh 3,840KB Upper 15/16 0 1 1 0 0 8 thru 63 080000h – 3FFFFFh 3,584KB Upper 7/8 0 1 1 0 1 16 thru 63 100000h – 3FFFFFh 3MB Upper 3/4 0 1 1 1 0 32 thru 63 200000h – 3FFFFFh 2MB Upper 1/2 X X 1 1 1 NONE NONE NONE NONE 1 0 0 0 1 0 thru 63 000000h – 3FEFFFh 4,092KB L - 1023/1024 1 0 0 1 0 0 thru 63 000000h – 3FDFFFh 4,088KB L - 511/512 1 0 0 1 1 0 thru 63 000000h – 3FBFFFh 4,080KB L - 255/256 1 0 1 0 X 0 thru 63 000000h – 3F7FFFh 4,064KB L - 127/128 1 1 0 0 1 0 thru 63 001000h – 3FFFFFh 4,092KB U - 1023/1024 1 1 0 1 0 0 thru 63 002000h – 3FFFFFh 4,088KB U - 511/512 1 1 0 1 1 0 thru 63 004000h – 3FFFFFh 4,080KB U - 255/256 1 1 1 0 X 0 thru 63 008000h – 3FFFFFh 4,064KB U - 127/128 Notes: 1. X = don’t care 2. L = Lower; U = Upper 3. If any Erase or Program command specifies a memory region that contains protected data portion, this command will be ignored. - 20 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW W25Q32FW Individual Block Memory Protection (WPS=1) Block 63 (64KB) 7.1.17 Sector 15 (4KB) Sector 14 (4KB) Sector 1 (4KB) Sector 0 (4KB) Individual Block Locks: 32 Sectors (Top/Bottom) 62 Blocks Block 62 (64KB) Individual Block Lock: 36h + Address Individual Block Unlock: 39h + Address Read Block Lock: 3Dh + Address Global Block Lock: 7Eh Block 0 (64KB) Block 1 (64KB) Global Block Unlock: 98h Sector 15 (4KB) Sector 14 (4KB) Sector 1 (4KB) Sector 0 (4KB) Figure 4d. Individual Block/Sector Locks Notes: 1. Individual Block/Sector protection is only valid when WPS=1. 2. All individual block/sector lock bits are set to 1 by default after power up, all memory array is protected. - 21 - W25Q32FW 8. INSTRUCTIONS The Standard/Dual/Quad SPI instruction set of the W25Q32FW consists of 45 basic instructions that are fully controlled through the SPI bus (see Instruction Set Table1-2). Instructions are initiated with the falling edge of Chip Select (/CS). The first byte of data clocked into the DI input provides the instruction code. Data on the DI input is sampled on the rising edge of clock with most significant bit (MSB) first. The QPI instruction set of the W25Q32FW consists of 32 basic instructions that are fully controlled through the SPI bus (see Instruction Set Table 3). Instructions are initiated with the falling edge of Chip Select (/CS). The first byte of data clocked through IO[3:0] pins provides the instruction code. Data on all four IO pins are sampled on the rising edge of clock with most significant bit (MSB) first. All QPI instructions, addresses, data and dummy bytes are using all four IO pins to transfer every byte of data with every two serial clocks (CLK). Instructions vary in length from a single byte to several bytes and may be followed by address bytes, data bytes, dummy bytes (don’t care), and in some cases, a combination. Instructions are completed with the rising edge of edge /CS. Clock relative timing diagrams for each instruction are included in Figures 5 through 57. All read instructions can be completed after any clocked bit. However, all instructions that Write, Program or Erase must complete on a byte boundary (/CS driven high after a full 8-bits have been clocked) otherwise the instruction will be ignored. This feature further protects the device from inadvertent writes. Additionally, while the memory is being programmed or erased, or when the Status Register is being written, all instructions except for Read Status Register will be ignored until the program or erase cycle has completed. 8.1 Device ID and Instruction Set Tables 8.1.1 Manufacturer and Device Identification MANUFACTURER ID (MF7 - MF0) Winbond Serial Flash EFh Device ID (ID7 - ID0) (ID15 - ID0) Instruction ABh, 90h, 92h, 94h 9Fh W25Q32FW 15h 6016h - 22 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.1.2 Instruction Set Table 1 (Standard SPI Instructions)(1) Data Input Output Number of Clock(1-1-1) Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 8 8 8 8 8 8 8 Dummy Dummy Dummy (ID7-ID0)(2) (MF7-MF0) (ID7-ID0) (UID63-0) Write Enable 06h Volatile SR Write Enable 50h Write Disable 04h Release Power-down / ID ABh Manufacturer/Device ID 90h Dummy Dummy 00h JEDEC ID 9Fh (MF7-MF0) (ID15-ID8) (ID7-ID0) Read Unique ID 4Bh Dummy Dummy Dummy Dummy Read Data 03h A23-A16 A15-A8 A7-A0 (D7-D0) Fast Read 0Bh A23-A16 A15-A8 A7-A0 Dummy (D7-D0) Page Program 02h A23-A16 A15-A8 A7-A0 D7-D0 D7-D0(3) Sector Erase (4KB) 20h A23-A16 A15-A8 A7-A0 Block Erase (32KB) 52h A23-A16 A15-A8 A7-A0 Block Erase (64KB) D8h A23-A16 A15-A8 A7-A0 Dummy (D7-D0) Chip Erase C7h/60h 05h (S7-S0)(2) Write Status Register-1 01h (S7-S0)(4) Read Status Register-2 35h (S15-S8)(2) Write Status Register-2 31h (S15-S8) Read Status Register-3 15h (S23-S16)(2) Write Status Register-3 11h (S23-S16) Read SFDP Register 5Ah A23-A16 A15-A8 A7-A0 44h A23-A16 A15-A8 A7-A0 42h A23-A16 A15-A8 A7-A0 D7-D0 D7-D0(3) 48h A23-A16 A15-A8 A7-A0 Dummy (D7-D0) (L7-L0) Read Status Register-1 (4) Erase Security Register (5) Program Security Register(5) Read Security Register (5) Global Block Lock 7Eh Global Block Unlock 98h Read Block Lock 3Dh A23-A16 A15-A8 A7-A0 Individual Block Lock 36h A23-A16 A15-A8 A7-A0 Individual Block Unlock 39h A23-A16 A15-A8 A7-A0 Erase / Program Suspend 75h Erase / Program Resume 7Ah Power-down B9h Enter QPI Mode 38h Enable Reset 66h Reset Device 99h - 23 - W25Q32FW 8.1.3 Instruction Set Table 2 (Dual/Quad SPI Instructions)(1) Data Input Output Number of Clock(1-1-2) Byte 1 8 Byte 2 8 Byte 3 8 Byte 4 8 Byte 5 4 Byte 6 4 Byte 7 4 Fast Read Dual Output 3Bh A23-A16 A15-A8 A7-A0 Dummy Dummy (D7-D0)(7) 4 Number of Clock(1-2-2) 8 4 4 4 4 4 Fast Read Dual I/O BBh A23-A16 A15-A8 A7-A0 M7-M0 (D7-D0) Mftr./Device ID Dual I/O 92h A23-A16 A15-A8 00 M7-M0(15) (MF7-MF0) (ID7-ID0) Number of Clock(1-1-4) 8 8 8 8 2 2 2 Byte 8 4 4 2 … (3) Quad Input Page Program 32h A23-A16 A15-A8 A7-A0 (D7-D0) Fast Read Quad Output 6Bh A23-A16 A15-A8 A7-A0 Dummy Dummy Dummy (D7-D0)(9) Number of Clock(1-4-4) 8 2 2 2 2 2 2 2 Mftr./Device ID Quad I/O 94h A23-A16 A15-A8 00 M7-M0(15) Dummy Dummy (MF7-MF0) Fast Read Quad I/O EBh A23-A16 A15-A8 A7-A0 M7-M0 Dummy Dummy (D7-D0) Set Burst with Wrap 77h Dummy Dummy Dummy W8-W0 - 24 - (D7-D0) Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.1.4 Instruction Set Table 3 (QPI Instructions)(14) Data Input Output Number of Clock (4-4-4) Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 2 2 2 2 2 2 2 Dummy Dummy Dummy (ID7-ID0)(2) (MF7-MF0) (ID7-ID0) Write Enable 06h Volatile SR Write Enable 50h Write Disable 04h Release Power-down / ID ABh Manufacturer/Device ID 90h Dummy Dummy 00h JEDEC ID 9Fh (MF7-MF0) (ID15-ID8) (ID7-ID0) Set Read Parameters C0h P7-P0 0Bh A23-A16 A15-A8 A7-A0 Dummy(12) (D7-D0) … Burst Read with Wrap 0Ch A23-A16 A15-A8 A7-A0 Dummy(12) (D7-D0) … Fast Read Quad I/O EBh A23-A16 A15-A8 A7-A0 M7-M0 (D7-D0) … Page Program 02h A23-A16 A15-A8 A7-A0 D7-D0(9) D7-D0(3) … Sector Erase (4KB) 20h A23-A16 A15-A8 A7-A0 Block Erase (32KB) 52h A23-A16 A15-A8 A7-A0 Block Erase (64KB) D8h A23-A16 A15-A8 A7-A0 Fast Read (14) Chip Erase C7h/60h 05h (S7-S0)(2) Write Status Register-1 01h (S7-S0)(4) Read Status Register-2 35h (S15-S8)(2) Write Status Register-2 31h (S15-S8) Read Status Register-3 15h (S23-S16)(2) Write Status Register-3 11h (S23-S16) Global Block Lock 7Eh Read Status Register-1 (4) Global Block Unlock 98h Read Block Lock 3Dh A23-A16 A15-A8 A7-A0 Individual Block Lock 36h A23-A16 A15-A8 A7-A0 Individual Block Unlock 39h A23-A16 A15-A8 A7-A0 Erase / Program Suspend 75h Erase / Program Resume 7Ah Power-down B9h Enable Reset 66h Reset Device 99h Exit QPI Mode FFh - 25 - (L7-L0) W25Q32FW Notes: 1. Data bytes are shifted with Most Significant Bit first. Byte fields with data in parenthesis “( )” indicate data output from the device on either 1, 2 or 4 IO pins. 2. The Status Register contents and Device ID will repeat continuously until /CS terminates the instruction. 3. At least one byte of data input is required for Page Program, Quad Page Program and Program Security Registers, up to 256 bytes of data input. If more than 256 bytes of data are sent to the device, the addressing will wrap to the beginning of the page and overwrite previously sent data. 4. Write Status Register-1 (01h) can also be used to program Status Register-1&2, see section 8.2.5. 5. Security Register Address: Security Register 1: A23-16 = 00h; A15-8 = 10h; A7-0 = byte address Security Register 2: A23-16 = 00h; A15-8 = 20h; A7-0 = byte address Security Register 3: A23-16 = 00h; A15-8 = 30h; A7-0 = byte address 6. Dual SPI address input format: IO0 = A22, A20, A18, A16, A14, A12, A10, A8 A6, A4, A2, A0, M6, M4, M2, M0 IO1 = A23, A21, A19, A17, A15, A13, A11, A9 A7, A5, A3, A1, M7, M5, M3, M1 7. Dual SPI data output format: IO0 = (D6, D4, D2, D0) IO1 = (D7, D5, D3, D1) 8. Quad SPI address input format: Set Burst with Wrap input format: IO0 = A20, A16, A12, A8, A4, A0, M4, M0 IO0 = x, x, x, x, x, x, W4, x IO1 = A21, A17, A13, A9, A5, A1, M5, M1 IO1 = x, x, x, x, x, x, W5, x IO2 = A22, A18, A14, A10, A6, A2, M6, M2 IO2 = x, x, x, x, x, x, W6, x IO3 = A23, A19, A15, A11, A7, A3, M7, M3 IO3 = x, x, x, x, x, x, x, x 9. Quad SPI data input/output format: IO0 = (D4, D0, …..) IO1 = (D5, D1, …..) IO2 = (D6, D2, …..) IO3 = (D7, D3, …..) 10. Fast Read Quad I/O data output format: IO0 = (x, x, x, x, D4, D0, D4, D0) IO1 = (x, x, x, x, D5, D1, D5, D1) IO2 = (x, x, x, x, D6, D2, D6, D2) IO3 = (x, x, x, x, D7, D3, D7, D3) 11. Word Read Quad I/O data output format: IO0 = (x, x, D4, D0, D4, D0, D4, D0) IO1 = (x, x, D5, D1, D5, D1, D5, D1) IO2 = (x, x, D6, D2, D6, D2, D6, D2) IO3 = (x, x, D7, D3, D7, D3, D7, D3) 12. QPI Command, Address, Data input/output format: CLK # 0 1 2 3 4 5 6 7 8 9 10 11 IO0 = C4, C0, A20, A16, A12, A8, A4, A0, D4, D0, D4, D0 IO1 = C5, C1, A21, A17, A13, A9, A5, A1, D5, D1, D5, D1 IO2 = C6, C2, A22, A18, A14, A10, A6, A2, D6, D2, D6, D2 IO3 = C7, C3, A23, A19, A15, A11, A7, A3, D7, D3, D7, D3 13. The number of dummy clocks for QPI Fast Read, QPI Fast Read Quad I/O & QPI Burst Read with Wrap is controlled by read parameter P7 – P4. 14. The wrap around length for QPI Burst Read with Wrap is controlled by read parameter P3 – P0. 15. For 92h and 94h, the “Continuous Read Mode” bits M7-0 must be set to Fxh to be compatible with Fast Read Dual/Quad I/O instruction - 26 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2 Instruction Descriptions 8.2.1 Write Enable (06h) The Write Enable instruction (Figure 5) sets the Write Enable Latch (WEL) bit in the Status Register to a 1. The WEL bit must be set prior to every Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register and Erase/Program Security Registers instruction. The Write Enable instruction is entered by driving /CS low, shifting the instruction code “06h” into the Data Input (DI) pin on the rising edge of CLK, and then driving /CS high. /CS Mode 3 /CS CLK Mode 3 CLK 0 1 2 3 4 5 6 7 Mode 0 Mode 3 0 1 Mode 0 Mode 3 Mode 0 Instruction 06h Mode 0 IO0 Instruction (06h) DI (IO0) IO1 IO2 High Impedance DO (IO1) IO3 Figure 5. Write Enable Instruction for SPI Mode (left) or QPI Mode (right) 8.2.2 Write Enable for Volatile Status Register (50h) The non-volatile Status Register bits described in section 7.1 can also be written to as volatile bits. This gives more flexibility to change the system configuration and memory protection schemes quickly without waiting for the typical non-volatile bit write cycles or affecting the endurance of the Status Register nonvolatile bits. To write the volatile values into the Status Register bits, the Write Enable for Volatile Status Register (50h) instruction must be issued prior to a Write Status Register (01h) instruction. Write Enable for Volatile Status Register instruction (Figure 6) will not set the Write Enable Latch (WEL) bit, it is only valid for the Write Status Register instruction to change the volatile Status Register bit values. /CS Mode 3 /CS CLK Mode 3 CLK 0 1 2 3 4 5 6 7 Mode 0 1 IO0 DI (IO0) IO1 IO2 High Impedance IO3 Figure 6. Write Enable for Volatile Status Register Instruction for SPI Mode (left) or QPI Mode (right) - 27 - Mode 3 Mode 0 Instruction 50h Mode 0 Instruction (50h) DO (IO1) Mode 3 0 Mode 0 W25Q32FW 8.2.3 Write Disable (04h) The Write Disable instruction (Figure 7) resets the Write Enable Latch (WEL) bit in the Status Register to a 0. The Write Disable instruction is entered by driving /CS low, shifting the instruction code “04h” into the DI pin and then driving /CS high. Note that the WEL bit is automatically reset after Power-up and upon completion of the Write Status Register, Erase/Program Security Registers, Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase and Reset instructions. /CS Mode 3 /CS CLK Mode 3 CLK 0 1 2 3 4 5 6 7 0 Mode 3 Mode 0 Mode 3 Mode 0 1 Mode 0 Instruction 04h Mode 0 IO0 Instruction (04h) DI (IO0) IO1 High Impedance DO (IO1) IO2 IO3 Figure 7. Write Disable Instruction for SPI Mode (left) or QPI Mode (right) 8.2.4 Read Status Register-1 (05h), Status Register-2 (35h) & Status Register-3 (15h) The Read Status Register instructions allow the 8-bit Status Registers to be read. The instruction is entered by driving /CS low and shifting the instruction code “05h” for Status Register-1, “35h” for Status Register-2 or “15h” for Status Register-3 into the DI pin on the rising edge of CLK. The status register bits are then shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first as shown in Figure 8. Refer to section 7.1 for Status Register descriptions. The Read Status Register instruction may be used at any time, even while a Program, Erase or Write Status Register cycle is in progress. This allows the BUSY status bit to be checked to determine when the cycle is complete and if the device can accept another instruction. The Status Register can be read continuously, as shown in Figure 8. The instruction is completed by driving /CS high. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 Mode 0 Instruction (05h/35h/15h) DI (IO0) High Impedance DO (IO1) * = MSB Status Register-1/2/3 out 7 6 5 * 4 3 2 1 Status Register-1/2/3 out 0 7 6 5 4 3 2 1 0 7 * Figure 8a. Read Status Register Instruction (SPI Mode) - 28 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW /CS Mode 3 CLK 0 1 2 3 4 5 Mode 0 Instruction 05h/35h/15h IO0 4 0 4 0 4 IO1 5 1 5 1 5 IO2 6 2 6 2 6 IO3 7 3 7 3 7 SR-1/2/3 out SR-1/2/3 out Figure 8b. Read Status Register Instruction (QPI Mode) 8.2.5 Write Status Register-1 (01h), Status Register-2 (31h) & Status Register-3 (11h) The Write Status Register instruction allows the Status Registers to be written. The writable Status Register bits include: SRP0, SEC, TB, BP[2:0] in Status Register-1; CMP, LB[3:1], QE, SRP1 in Status Register-2; HOLD/RST, DRV1, DRV0 & WPS in Status Register-3. All other Status Register bit locations are read-only and will not be affected by the Write Status Register instruction. LB[3:1] are non-volatile OTP bits, once it is set to 1, it cannot be cleared to 0. To write non-volatile Status Register bits, a standard Write Enable (06h) instruction must previously have been executed for the device to accept the Write Status Register instruction (Status Register bit WEL must equal 1). Once write enabled, the instruction is entered by driving /CS low, sending the instruction code “01h/31h/11h”, and then writing the status register data byte as illustrated in Figure 9a & 9b. To write volatile Status Register bits, a Write Enable for Volatile Status Register (50h) instruction must have been executed prior to the Write Status Register instruction (Status Register bit WEL remains 0). However, SRP1 and LB[3:1] cannot be changed from “1” to “0” because of the OTP protection for these bits. Upon power off or the execution of a Software/Hardware Reset, the volatile Status Register bit values will be lost, and the non-volatile Status Register bit values will be restored. During non-volatile Status Register write operation (06h combined with 01h/31h/11h), after /CS is driven high, the self-timed Write Status Register cycle will commence for a time duration of t W (See AC Characteristics). While the Write Status Register cycle is in progress, the Read Status Register instruction may still be accessed to check the status of the BUSY bit. The BUSY bit is a 1 during the Write Status Register cycle and a 0 when the cycle is finished and ready to accept other instructions again. After the Write Status Register cycle has finished, the Write Enable Latch (WEL) bit in the Status Register will be cleared to 0. - 29 - W25Q32FW During volatile Status Register write operation (50h combined with 01h/31h/11h), after /CS is driven high, the Status Register bits will be refreshed to the new values within the time period of t SHSL2 (See AC Characteristics). BUSY bit will remain 0 during the Status Register bit refresh period. The Write Status Register instruction can be used in both SPI mode and QPI mode. However, the QE bit cannot be written to when the device is in the QPI mode, because QE=1 is required for the device to enter and operate in the QPI mode. Refer to section 7.1 for Status Register descriptions. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Mode 0 Mode 3 Mode 0 Instruction (01h/31h/11h) Register-1/2/3 in DI (IO0) 7 6 5 4 3 2 1 0 * High Impedance DO (IO1) * = MSB Figure 9a. Write Status Register-1/2/3 Instruction (SPI Mode) /CS Mode 3 CLK 0 1 2 3 Mode 0 Mode 3 Mode 0 Instruction 01/31/11h SR1/2/3 in IO0 4 0 IO1 5 1 IO2 6 2 IO3 7 3 Figure 9b. Write Status Register-1/2/3 Instruction (QPI Mode) - 30 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW The W25Q32FW is also backward compatible to Winbond’s previous generations of serial flash memories, in which the Status Register-1&2 can be written using a single “Write Status Register-1 (01h)” command. To complete the Write Status Register-1&2 instruction, the /CS pin must be driven high after the sixteenth bit of data that is clocked in as shown in Figure 9c & 9d. If /CS is driven high after the eighth clock, the Write Status Register-1 (01h) instruction will only program the Status Register-1, the Status Register-2 will not be affected (Previous generations will clear CMP and QE bits). /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 Mode 0 Mode 3 Mode 0 Instruction (01h) Status Register 1 in DI (IO0) 7 6 5 4 3 Status Register 2 in 2 1 0 * 15 14 * High Impedance DO (IO1) * = MSB Figure 9c. Write Status Register-1/2 Instruction (SPI Mode) /CS Mode 3 CLK 0 1 2 3 4 5 Mode 0 Mode 3 Mode 0 Instruction 01h SR1 in SR2 in IO0 4 0 12 8 IO1 5 1 13 9 IO2 6 2 14 10 IO3 7 3 15 11 Figure 9d. Write Status Register-1/2 Instruction (QPI Mode) - 31 - 13 12 11 10 9 8 W25Q32FW 8.2.6 Read Data (03h) The Read Data instruction allows one or more data bytes to be sequentially read from the memory. The instruction is initiated by driving the /CS pin low and then shifting the instruction code “03h” followed by a 24-bit address (A23-A0) into the DI pin. The code and address bits are latched on the rising edge of the CLK pin. After the address is received, the data byte of the addressed memory location will be shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first. The address is automatically incremented to the next higher address after each byte of data is shifted out allowing for a continuous stream of data. This means that the entire memory can be accessed with a single instruction as long as the clock continues. The instruction is completed by driving /CS high. The Read Data instruction sequence is shown in Figure 14. If a Read Data instruction is issued while an Erase, Program or Write cycle is in process (BUSY=1) the instruction is ignored and will not have any effects on the current cycle. The Read Data instruction allows clock rates from D.C. to a maximum of f R (see AC Electrical Characteristics). The Read Data (03h) instruction is only supported in Standard SPI mode. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 28 29 30 31 32 33 34 35 36 37 38 39 Mode 0 Instruction (03h) DI (IO0) 24-Bit Address 23 22 21 3 2 1 0 * Data Out 1 High Impedance DO (IO1) 7 6 5 4 3 2 1 0 7 * * = MSB Figure 14. Read Data Instruction (SPI Mode only) - 32 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.7 Fast Read (0Bh) The Fast Read instruction is similar to the Read Data instruction except that it can operate at the highest possible frequency of FR (see AC Electrical Characteristics). This is accomplished by adding eight “dummy” clocks after the 24-bit address as shown in Figure 16. The dummy clocks allow the devices internal circuits additional time for setting up the initial address. During the dummy clocks the data value on the DO pin is a “don’t care”. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 28 29 30 31 Mode 0 Instruction (0Bh) 24-Bit Address DI (IO0) 23 22 21 42 43 3 2 1 0 45 46 47 48 * High Impedance DO (IO1) * = MSB /CS 31 32 33 34 35 36 37 38 39 40 41 44 49 50 51 52 53 54 55 CLK Dummy Clocks DI (IO0) DO (IO1) 0 High Impedance Data Out 1 7 6 5 4 3 Data Out 2 2 1 0 * 7 * Figure 16a. Fast Read Instruction (SPI Mode) - 33 - 6 5 4 3 2 1 0 7 W25Q32FW Fast Read (0Bh) in QPI Mode The Fast Read instruction is also supported in QPI mode. When QPI mode is enabled, the number of dummy clocks is configured by the “Set Read Parameters (C0h)” instruction to accommodate a wide range of applications with different needs for either maximum Fast Read frequency or minimum data access latency. Depending on the Read Parameter Bits P[5:4] setting, the number of dummy clocks can be configured as either 2, 4, 6 or 8. The default number of dummy clocks upon power up or after a Reset instruction is 2. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 Mode 0 Instruction 0Bh A23-16 A15-8 A7-0 IOs switch from Input to Output Dummy* IO0 20 16 12 8 4 0 4 0 4 0 4 0 4 IO1 21 17 13 9 5 1 5 1 5 1 5 1 5 IO2 22 18 14 10 6 2 6 2 6 2 6 2 6 IO3 23 19 15 11 7 3 7 3 7 3 7 3 7 Byte 1 Byte 2 * "Set Read Parameters" instruction (C0h) can set the number of dummy clocks. Figure 16b. Fast Read Instruction (QPI Mode) - 34 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.8 Fast Read Dual Output (3Bh) The Fast Read Dual Output (3Bh) instruction is similar to the standard Fast Read (0Bh) instruction except that data is output on two pins; IO0 and IO1. This allows data to be transferred at twice the rate of standard SPI devices. The Fast Read Dual Output instruction is ideal for quickly downloading code from Flash to RAM upon power-up or for applications that cache code-segments to RAM for execution. Similar to the Fast Read instruction, the Fast Read Dual Output instruction can operate at the highest possible frequency of FR (see AC Electrical Characteristics). This is accomplished by adding eight “dummy” clocks after the 24-bit address as shown in Figure 18. The dummy clocks allow the device's internal circuits additional time for setting up the initial address. The input data during the dummy clocks is “don’t care”. However, the IO0 pin should be high-impedance prior to the falling edge of the first data out clock. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 28 29 30 31 Mode 0 Instruction (3Bh) 24-Bit Address DI (IO0) 23 22 21 42 43 3 2 1 0 45 46 47 48 * High Impedance DO (IO1) * = MSB /CS 31 32 33 34 35 36 37 38 39 40 41 44 49 50 51 52 53 54 55 CLK IO0 switches from Input to Output Dummy Clocks DI (IO0) DO (IO1) 0 High Impedance 6 4 2 0 6 4 2 0 6 4 2 0 6 4 2 0 6 7 5 3 1 7 5 3 1 7 5 3 1 7 5 3 1 7 * Data Out 1 * Data Out 2 * Data Out 3 Figure 18. Fast Read Dual Output Instruction (SPI Mode only) - 35 - * Data Out 4 W25Q32FW 8.2.9 Fast Read Quad Output (6Bh) The Fast Read Quad Output (6Bh) instruction is similar to the Fast Read Dual Output (3Bh) instruction except that data is output on four pins, IO0, IO1, IO2, and IO3. The Quad Enable (QE) bit in Status Register2 must be set to 1 before the device will accept the Fast Read Quad Output Instruction. The Fast Read Quad Output Instruction allows data to be transferred at four times the rate of standard SPI devices. The Fast Read Quad Output instruction can operate at the highest possible frequency of FR (see AC Electrical Characteristics). This is accomplished by adding eight “dummy” clocks after the 24-bit address as shown in Figure 20. The dummy clocks allow the device's internal circuits additional time for setting up the initial address. The input data during the dummy clocks is “don’t care”. However, the IO pins should be high-impedance prior to the falling edge of the first data out clock. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 28 29 30 31 Mode 0 Instruction (6Bh) 24-Bit Address IO0 23 High Impedance IO1 22 21 42 43 3 2 1 45 46 47 0 * High Impedance IO2 High Impedance IO3 * = MSB /CS 31 32 33 34 35 36 37 38 39 40 41 44 CLK IO0 switches from Input to Output Dummy Clocks IO0 IO1 IO2 IO3 0 High Impedance High Impedance High Impedance 4 0 4 0 4 0 4 0 4 5 1 5 1 5 1 5 1 5 6 2 6 2 6 2 6 2 6 7 3 7 3 7 3 7 3 7 Byte 1 Byte 2 Byte 3 Byte 4 Figure 20. Fast Read Quad Output Instruction (SPI Mode only) - 36 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.10 Fast Read Dual I/O (BBh) The Fast Read Dual I/O (BBh) instruction allows for improved random access while maintaining two IO pins, IO0 and IO1. It is similar to the Fast Read Dual Output (3Bh) instruction but with the capability to input the Address bits (A23-0) two bits per clock. This reduced instruction overhead may allow for code execution (XIP) directly from the Dual SPI in some applications. Fast Read Dual I/O with “Continuous Read Mode” The Fast Read Dual I/O instruction can further reduce instruction overhead through setting the “Continuous Read Mode” bits (M7-0) after the input Address bits (A23-0), as shown in Figure 22a. The upper nibble of the (M7-4) controls the length of the next Fast Read Dual I/O instruction through the inclusion or exclusion of the first byte instruction code. The lower nibble bits of the (M3-0) are don’t care (“x”). However, the IO pins should be high-impedance prior to the falling edge of the first data out clock. If the “Continuous Read Mode” bits M5-4 = (1,0), then the next Fast Read Dual I/O instruction (after /CS is raised and then lowered) does not require the BBh instruction code, as shown in Figure 22b. This reduces the instruction sequence by eight clocks and allows the Read address to be immediately entered after /CS is asserted low. If the “Continuous Read Mode” bits M5-4 do not equal to (1,0), the next instruction (after /CS is raised and then lowered) requires the first byte instruction code, thus returning to normal operation. It is recommended to input FFFFh on IO0 for the next instruction (16 clocks), to ensure M4 = 1 and return the device to normal operation. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 Mode 0 Instruction (BBh) A23-16 A15-8 A7-0 M7-0 DI (IO0) 22 20 18 16 14 12 10 8 6 4 2 0 6 4 2 0 DO (IO1) 23 21 19 17 15 13 11 9 7 5 3 1 7 5 3 1 * * = MSB * /CS 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 CLK IOs switch from Input to Output DI (IO0) 0 6 4 2 0 6 4 2 0 6 4 2 0 6 4 2 0 6 DO (IO1) 1 7 5 3 1 7 5 3 1 7 5 3 1 7 5 3 1 7 * Byte 1 * Byte 2 * Byte 3 * Byte 4 Figure 22a. Fast Read Dual I/O Instruction (Initial instruction or previous M5-410, SPI Mode) - 37 - W25Q32FW /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Mode 0 A23-16 A15-8 A7-0 M7-0 DI (IO0) 22 20 18 16 14 12 10 8 6 4 2 0 6 4 2 0 DO (IO1) 23 21 19 17 15 13 11 9 7 5 3 1 7 5 3 1 30 31 * * /CS 15 * = MSB 16 17 18 19 20 21 22 23 24 25 26 27 28 29 CLK IOs switch from Input to Output DI (IO0) 0 6 4 2 0 6 4 2 0 6 4 2 0 6 4 2 0 6 DO (IO1) 1 7 5 3 1 7 5 3 1 7 5 3 1 7 5 3 1 7 * Byte 1 * Byte 2 * Byte 3 * Byte 4 Figure 22b. Fast Read Dual I/O Instruction (Previous instruction set M5-4 = 10, SPI Mode only) - 38 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.11 Fast Read Quad I/O (EBh) The Fast Read Quad I/O (EBh) instruction is similar to the Fast Read Dual I/O (BBh) instruction except that address and data bits are input and output through four pins IO 0, IO1, IO2 and IO3 and four Dummy clocks are required in SPI mode prior to the data output. The Quad I/O dramatically reduces instruction overhead allowing faster random access for code execution (XIP) directly from the Quad SPI. The Quad Enable bit (QE) of Status Register-2 must be set to enable the Fast Read Quad I/O Instruction. Fast Read Quad I/O with “Continuous Read Mode” The Fast Read Quad I/O instruction can further reduce instruction overhead through setting the “Continuous Read Mode” bits (M7-0) after the input Address bits (A23-0), as shown in Figure 24a. The upper nibble of the (M7-4) controls the length of the next Fast Read Quad I/O instruction through the inclusion or exclusion of the first byte instruction code. The lower nibble bits of the (M3-0) are don’t care (“x”). However, the IO pins should be high-impedance prior to the falling edge of the first data out clock. If the “Continuous Read Mode” bits M5-4 = (1,0), then the next Fast Read Quad I/O instruction (after /CS is raised and then lowered) does not require the EBh instruction code, as shown in Figure 24b. This reduces the instruction sequence by eight clocks and allows the Read address to be immediately entered after /CS is asserted low. If the “Continuous Read Mode” bits M5-4 do not equal to (1,0), the next instruction (after /CS is raised and then lowered) requires the first byte instruction code, thus returning to normal operation. It is recommended to input FFh on IO0 for the next instruction (8 clocks), to ensure M4 = 1 and return the device to normal operation. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 Mode 0 Instruction (EBh) A23-16 A15-8 A7-0 M7-0 Dummy IOs switch from Input to Output Dummy IO0 20 16 12 8 4 0 4 0 4 0 4 0 4 IO1 21 17 13 9 5 1 5 1 5 1 5 1 5 IO2 22 18 14 10 6 2 6 2 6 2 6 2 6 IO3 23 19 15 11 7 3 7 3 7 3 7 3 7 Byte 1 Figure 24a. Fast Read Quad I/O Instruction (Initial instruction or previous M5-410, SPI Mode) - 39 - Byte 2 Byte 3 W25Q32FW /CS Mode 3 CLK 0 1 2 3 4 6 5 7 8 9 10 11 12 13 14 15 Mode 0 A23-16 A15-8 A7-0 M7-0 Dummy IOs switch from Input to Output Dummy IO0 20 16 12 8 4 0 4 0 4 0 4 0 4 IO1 21 17 13 9 5 1 5 1 5 1 5 1 5 IO2 22 18 14 10 6 2 6 2 6 2 6 2 6 IO3 23 19 15 11 7 3 7 3 7 3 7 3 7 Byte 1 Byte 2 Byte 3 Figure 24b. Fast Read Quad I/O Instruction (Previous instruction set M5-4 = 10, SPI Mode) Fast Read Quad I/O with “8/16/32/64-Byte Wrap Around” in Standard SPI mode The Fast Read Quad I/O instruction can also be used to access a specific portion within a page by issuing a “Set Burst with Wrap” (77h) command prior to EBh. The “Set Burst with Wrap” (77h) command can either enable or disable the “Wrap Around” feature for the following EBh commands. When “Wrap Around” is enabled, the data being accessed can be limited to either an 8, 16, 32 or 64-byte section of a 256-byte page. The output data starts at the initial address specified in the instruction, once it reaches the ending boundary of the 8/16/32/64-byte section, the output will wrap around to the beginning boundary automatically until /CS is pulled high to terminate the command. The Burst with Wrap feature allows applications that use cache to quickly fetch a critical address and then fill the cache afterwards within a fixed length (8/16/32/64-byte) of data without issuing multiple read commands. The “Set Burst with Wrap” instruction allows three “Wrap Bits”, W6-4 to be set. The W4 bit is used to enable or disable the “Wrap Around” operation while W6-5 are used to specify the length of the wrap around section within a page. Refer to section 8.2.24 for detail descriptions. - 40 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW Fast Read Quad I/O (EBh) in QPI Mode The Fast Read Quad I/O instruction is also supported in QPI mode, as shown in Figure 19c. When QPI mode is enabled, the number of dummy clocks is configured by the “Set Read Parameters (C0h)” instruction to accommodate a wide range of applications with different needs for either maximum Fast Read frequency or minimum data access latency. Depending on the Read Parameter Bits P[5:4] setting, the number of dummy clocks can be configured as either 2, 4, 6 or 8. The default number of dummy clocks upon power up or after a Reset instruction is 2. In QPI mode, the “Continuous Read Mode” bits M7-0 are also considered as dummy clocks. In the default setting, the data output will follow the Continuous Read Mode bits immediately. “Continuous Read Mode” feature is also available in QPI mode for Fast Read Quad I/O instruction. Please refer to the description on previous pages. “Wrap Around” feature is not available in QPI mode for Fast Read Quad I/O instruction. To perform a read operation with fixed data length wrap around in QPI mode, a dedicated “Burst Read with Wrap” (0Ch) instruction must be used. Please refer to 8.2.45 for details. /CS Mode 3 CLK 0 1 2 3 4 6 5 7 8 9 10 11 12 13 14 Mode 0 Instruction EBh A23-16 A15-8 A7-0 IOs switch from Input to Output M7-0* IO0 20 16 12 8 4 0 4 0 4 0 4 0 4 IO1 21 17 13 9 5 1 5 1 5 1 5 1 5 IO2 22 18 14 10 6 2 6 2 6 2 6 2 6 IO3 23 19 15 11 7 3 7 3 7 3 7 3 7 Byte 1 Byte 2 Byte 3 * "Set Read Parameters" instruction (C0h) can set the number of dummy clocks. Figure 24c. Fast Read Quad I/O Instruction (Initial instruction or previous M5-410, QPI Mode) - 41 - W25Q32FW 8.2.12 Set Burst with Wrap (77h) In Standard SPI mode, the Set Burst with Wrap (77h) instruction is used in conjunction with “Fast Read Quad I/O” and “Word Read Quad I/O” instructions to access a fixed length of 8/16/32/64-byte section within a 256-byte page. Certain applications can benefit from this feature and improve the overall system code execution performance. Similar to a Quad I/O instruction, the Set Burst with Wrap instruction is initiated by driving the /CS pin low and then shifting the instruction code “77h” followed by 24 dummy bits and 8 “Wrap Bits”, W7-0. The instruction sequence is shown in Figure 28. Wrap bit W7 and the lower nibble W3-0 are not used. W4 = 0 W6, W5 0 0 1 1 W4 =1 (DEFAULT) Wrap Around Wrap Length Wrap Around Wrap Length Yes Yes Yes Yes 8-byte 16-byte 32-byte 64-byte No No No No N/A N/A N/A N/A 0 1 0 1 Once W6-4 is set by a Set Burst with Wrap instruction, all the following “Fast Read Quad I/O” and “Word Read Quad I/O” instructions will use the W6-4 setting to access the 8/16/32/64-byte section within any page. To exit the “Wrap Around” function and return to normal read operation, another Set Burst with Wrap instruction should be issued to set W4 = 1. The default value of W4 upon power on or after a software/hardware reset is 1. In QPI mode, the “Burst Read with Wrap (0Ch)” instruction should be used to perform the Read operation with “Wrap Around” feature. The Wrap Length set by W5-4 in Standard SPI mode is still valid in QPI mode and can also be re-configured by “Set Read Parameters (C0h)” instruction. Refer to 8.2.44 and 8.2.45 for details. /CS Mode 3 CLK 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Mode 0 Mode 3 Mode 0 don't care Instruction (77h) don't care don't care Wrap Bit IO0 X X X X X X w4 X IO1 X X X X X X w5 X IO2 X X X X X X w6 X IO3 X X X X X X X X Figure 28. Set Burst with Wrap Instruction (SPI Mode only) - 42 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.13 Page Program (02h) The Page Program instruction allows from one byte to 256 bytes (a page) of data to be programmed at previously erased (FFh) memory locations. A Write Enable instruction must be executed before the device will accept the Page Program Instruction (Status Register bit WEL= 1). The instruction is initiated by driving the /CS pin low then shifting the instruction code “02h” followed by a 24-bit address (A23-A0) and at least one data byte, into the DI pin. The /CS pin must be held low for the entire length of the instruction while data is being sent to the device. The Page Program instruction sequence is shown in Figure 29. If an entire 256 byte page is to be programmed, the last address byte (the 8 least significant address bits) should be set to 0. If the last address byte is not zero, and the number of clocks exceeds the remaining page length, the addressing will wrap to the beginning of the page. In some cases, less than 256 bytes (a partial page) can be programmed without having any effect on other bytes within the same page. One condition to perform a partial page program is that the number of clocks cannot exceed the remaining page length. If more than 256 bytes are sent to the device the addressing will wrap to the beginning of the page and overwrite previously sent data. As with the write and erase instructions, the /CS pin must be driven high after the eighth bit of the last byte has been latched. If this is not done the Page Program instruction will not be executed. After /CS is driven high, the self-timed Page Program instruction will commence for a time duration of tpp (See AC Characteristics). While the Page Program cycle is in progress, the Read Status Register instruction may still be accessed for checking the status of the BUSY bit. The BUSY bit is a 1 during the Page Program cycle and becomes a 0 when the cycle is finished and the device is ready to accept other instructions again. After the Page Program cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Page Program instruction will not be executed if the addressed page is protected by the Block Protect (CMP, SEC, TB, BP2, BP1, and BP0) bits or the Individual Block/Sector Locks. /CS Mode 3 0 1 2 3 4 5 6 7 8 9 10 28 29 30 31 32 33 34 35 36 37 38 39 Mode 0 1 * 0 6 5 4 3 2 1 0 2079 Data Byte 1 2 2078 3 2077 21 2076 22 2075 24-Bit Address 23 2074 Instruction (02h) DI (IO0) 2073 CLK 7 * * = MSB 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 2072 /CS CLK Mode 0 Data Byte 2 DI (IO0) Mode 3 0 7 * 6 5 4 3 Data Byte 3 2 1 0 7 6 5 4 3 * Data Byte 256 2 1 0 7 * Figure 29a. Page Program Instruction (SPI Mode) - 43 - 6 5 4 3 2 1 0 W25Q32FW 2 3 4 5 6 7 8 9 10 11 12 13 519 1 518 0 517 Mode 3 CLK 516 /CS Mode 0 Mode 3 Mode 0 Instruction 02h A23-16 A15-8 A7-0 Byte1 Byte 2 Byte 3 Byte 255 Byte 256 IO0 20 16 12 8 4 0 4 0 4 0 4 0 4 0 4 0 IO1 21 17 13 9 5 1 5 1 5 1 5 1 5 1 5 1 IO2 22 18 14 10 6 2 6 2 6 2 6 2 6 2 6 2 IO3 23 19 15 11 7 3 7 3 7 3 7 3 7 3 7 3 Figure 29b. Page Program Instruction (QPI Mode) - 44 - Publication Release Date: July 01, 2016 - Revision H W25Q32FW 8.2.14 Quad Input Page Program (32h) The Quad Page Program instruction allows up to 256 bytes of data to be programmed at previously erased (FFh) memory locations using four pins: IO0, IO1, IO2, and IO3. The Quad Page Program can improve performance for PROM Programmer and applications that have slow clock speeds
W25Q32FWBYIG TR 价格&库存

很抱歉,暂时无法提供与“W25Q32FWBYIG TR”相匹配的价格&库存,您可以联系我们找货

免费人工找货